package com.atguigu.ssyx.search.service.Impl;

import com.atguigu.ssyx.client.activity.ActivityFeignClient;
import com.atguigu.ssyx.client.product.ProductFeignClient;
import com.atguigu.ssyx.common.auth.AuthContextHolder;
import com.atguigu.ssyx.enums.SkuType;
import com.atguigu.ssyx.model.product.Category;
import com.atguigu.ssyx.model.product.SkuInfo;
import com.atguigu.ssyx.model.search.SkuEs;
import com.atguigu.ssyx.search.repository.SkuRepository;
import com.atguigu.ssyx.search.service.SkuService;
import com.atguigu.ssyx.vo.search.SkuEsQueryVo;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.PageRequest;
import org.springframework.data.domain.Pageable;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.stereotype.Service;
import org.springframework.util.CollectionUtils;
import org.springframework.util.StringUtils;

import java.util.Collections;
import java.util.List;
import java.util.Map;
import java.util.Optional;
import java.util.stream.Collectors;

/**
 * @作者:胡树苑
 * @时间:2025/9/17 13:48
 */
@Service
public class SkuServiceImpl implements SkuService {
    @Autowired
    private SkuRepository skuRepository;
    @Autowired
    private ProductFeignClient productFeignClient;
    @Autowired
    private ActivityFeignClient activityFeignClient;
    @Autowired
    private RedisTemplate redisTemplate;
    @Override
    public void upperSku(Long skuId) {
        //1.通过远程调用，根据skuid获得相关信息，基本信息和分类信息
        SkuInfo skuInfo = productFeignClient.getSkuInfo(skuId);
        if (skuInfo == null) {
            return;
        }
        Category category = productFeignClient.getCategory(skuInfo.getCategoryId());

        //2.获取数据封装SkuEs对象
        SkuEs skuEs = new SkuEs();
        if(category != null) {
            skuEs.setCategoryId(category.getId());
            skuEs.setCategoryName(category.getName());
        }
        //封装sku信息部分
        skuEs.setId(skuInfo.getId());
        skuEs.setKeyword(skuInfo.getSkuName()+","+skuEs.getCategoryName());
        skuEs.setWareId(skuInfo.getWareId());
        skuEs.setIsNewPerson(skuInfo.getIsNewPerson());
        skuEs.setImgUrl(skuInfo.getImgUrl());
        skuEs.setTitle(skuInfo.getSkuName());
        if(skuInfo.getSkuType() == SkuType.COMMON.getCode()) { //普通商品
            skuEs.setSkuType(0);
            skuEs.setPrice(skuInfo.getPrice().doubleValue());
            skuEs.setStock(skuInfo.getStock());
            skuEs.setSale(skuInfo.getSale());
            skuEs.setPerLimit(skuInfo.getPerLimit());
        } else if(skuInfo.getSkuType() == SkuType.SECKILL.getCode()) { //秒杀商品
            skuEs.setSkuType(1);
            skuEs.setPrice(skuInfo.getPrice().doubleValue());
            skuEs.setStock(skuInfo.getStock());
            skuEs.setSale(skuInfo.getSale());
            skuEs.setPerLimit(skuInfo.getPerLimit());
        }
        //3.调用方法添加到ES
        skuRepository.save(skuEs);
    }
    //下架
    @Override
    public void lowerSku(Long skuId) {
        skuRepository.deleteById(skuId);
    }

    @Override
    public List<SkuEs> findHotSkuList() {
        //Spring data
        //find read get 开头
        //关联条件关键字
        //0代表第一页
        //findByOrderByHotScoreDesc()
        Pageable pageable = PageRequest.of(0, 10);
        Page<SkuEs> pageModel= skuRepository.findByOrderByHotScoreDesc(pageable);
        List<SkuEs> skuEsList = pageModel.getContent();
        
        //查询商品参加优惠活动
        if(!CollectionUtils.isEmpty(skuEsList)) {
            //遍历skuEslist 得到skuId
            List<Long> skuIdList = skuEsList.stream().map(SkuEs::getId).collect(Collectors.toList());
            //根据skuid列表远程调用，调用service=activity里面的接口得到数据
            Map<Long,List<String>> skuIdToRuleListMap = activityFeignClient.findActivity(skuIdList);
            //封装获取数据到skuEs里面的ruleList里面
            if(skuIdToRuleListMap!=null) {
                skuEsList.forEach(skuEs -> {
                    skuEs.setRuleList(skuIdToRuleListMap.get(skuEs.getId()));
                });
            }
        }
        
        return skuEsList;
    }
    //查询分类商品
    @Override
    public Page<SkuEs> search(Pageable pageable, SkuEsQueryVo skuEsQueryVo) {
        //1向skuesqueryvo设置仓库id,当前登录拥护的仓库id
        skuEsQueryVo.setWareId(AuthContextHolder.getWareId());
        Page<SkuEs> pageModel = null;
        //2 查询 调用SkuRepository 方法根据springdata命名规则定义方法，进行条件查询
        //判断keyword是否为空 为空根据仓库id+分类id查询

        String keyword = skuEsQueryVo.getKeyword();
        if(StringUtils.isEmpty(keyword)) {
            pageModel=
            skuRepository.findByCategoryIdAndWareId(
                    skuEsQueryVo.getCategoryId(),
                    skuEsQueryVo.getWareId(),
                    pageable);
        }else{
            //不为空则根据仓库id+分类id+keyword
            pageModel=
                    skuRepository.findByKeywordAndWareId(
                            skuEsQueryVo.getKeyword(),
                            skuEsQueryVo.getWareId(),
                            pageable
                    );
        }
        //3查询商品参加优惠活动
        List<SkuEs> skuEsList = pageModel.getContent();
        if(!CollectionUtils.isEmpty(skuEsList)) {
            //遍历skuEslist 得到skuId
            List<Long> skuIdList = skuEsList.stream().map(SkuEs::getId).collect(Collectors.toList());
            //根据skuid列表远程调用，调用service=activity里面的接口得到数据
            Map<Long,List<String>> skuIdToRuleListMap = activityFeignClient.findActivity(skuIdList);
            //封装获取数据到skuEs里面的ruleList里面
            if(skuIdToRuleListMap!=null) {
                skuEsList.forEach(skuEs -> {
                    skuEs.setRuleList(skuIdToRuleListMap.get(skuEs.getId()));
                });
            }
        }

        return pageModel;
    }
    //更新商品热度
    @Override
    public void incrHotScore(Long skuId) {
        String key = "hotScore";
        //redis 保存数据 每次+1
        Double hotScore = redisTemplate.opsForZSet().incrementScore(key, "skuId:" + skuId, 1);
        //规则
        if(hotScore%10==0){
            //更新es
            Optional<SkuEs> optional = skuRepository.findById(skuId);
            SkuEs skuEs = optional.get();
            skuEs.setHotScore(Math.round(hotScore));
            skuRepository.save(skuEs);
        }
    }
}
